home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Skunkware 98
/
Skunkware 98.iso
/
src
/
mail
/
pine3.96.tar.gz
/
pine3.96.tar
/
pine3.96
/
imap
/
ANSI
/
c-client
/
log_sos.c
< prev
next >
Wrap
Text File
|
1995-08-31
|
3KB
|
68 lines
/*
* Program: OSF/1 server login
*
* Author: Mark Crispin
* Networks and Distributed Computing
* Computing & Communications
* University of Washington
* Administration Building, AG-44
* Seattle, WA 98195
* Internet: MRC@CAC.Washington.EDU
*
* Date: 1 August 1988
* Last Edited: 31 August 1995
*
* Copyright 1995 by the University of Washington
*
* Permission to use, copy, modify, and distribute this software and its
* documentation for any purpose and without fee is hereby granted, provided
* that the above copyright notice appears in all copies and that both the
* above copyright notice and this permission notice appear in supporting
* documentation, and that the name of the University of Washington not be
* used in advertising or publicity pertaining to distribution of the software
* without specific, written prior permission. This software is made available
* "as is", and
* THE UNIVERSITY OF WASHINGTON DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED,
* WITH REGARD TO THIS SOFTWARE, INCLUDING WITHOUT LIMITATION ALL IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, AND IN
* NO EVENT SHALL THE UNIVERSITY OF WASHINGTON BE LIABLE FOR ANY SPECIAL,
* INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
* LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, TORT
* (INCLUDING NEGLIGENCE) OR STRICT LIABILITY, ARISING OUT OF OR IN CONNECTION
* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
*/
/* Server log in
* Accepts: user name string
* password string
* optional place to return home directory
* Returns: T if password validated, NIL otherwise
*/
long server_login (char *user,char *pass,char **home,int argc,char *argv[])
{
char tmp[MAILTMPLEN];
struct passwd *pw;
struct pr_passwd *prpw;
set_auth_parameters (argc,argv);
/* allow case-independent match */
if (!(pw = getpwnam (user))) pw = getpwnam (lcase (strcpy (tmp,user)));
/* no entry for this user or root */
if (!(pw && pw->pw_uid)) return NIL;
/* note home directory */
if (home) *home = cpystr (pw->pw_dir);
/* validate password */
if (strcmp (pw->pw_passwd,(char *) crypt (pass,pw->pw_passwd))) {
/* possibly in secure mode */
struct pr_passwd *prpw = getprpwnam (user);
if (!(prpw && prpw->ufld.fd_uid)) return NIL;
if (strcmp (prpw->ufld.fd_encrypt,bigcrypt (pass,prpw->ufld.fd_encrypt)))
return NIL;
}
setgid (pw->pw_gid); /* all OK, login in as that user */
initgroups (user,pw->pw_gid); /* initialize groups */
setuid (pw->pw_uid);
return env_init (pw->pw_name,pw->pw_dir);
}